<?php

namespace app\admin\controller;

use think\Controller;
use think\Request;
use think\Db;

class Advertisingby extends AdminController
{
    /**
     * 显示广告信息表
     *
     * @return \think\Response
     */
    public function index()
    {
      //从数据库里查询广告信息表里的信息
       $data = Db::table('lt_carouser_pic')->paginate(3);
      //渲染输出广告信息表

        return view('Advertising/advlist',[
            'data'=>$data,
        ]);
    }

    /**
     * 显示轮播广告栏位的添加页.
     *
     * @return \think\Response
     */
    public function create()
    {
        //渲染输出轮播广告的添加页
        return view('Advertising/advadd');

    }

    /**
     * 保存添加的广告内容
     *
     * @param  \think\Request  $request
     * @return \think\Response
     */
    public function save(Request $request)
    {
         //接受post传来的数据
        $result=$request->post();
        // 获取表单上传文件 例如上传了001.jpg
        $file = request()->file('upload_path');
        // 移动到框架应用根目录/public/uploads/ 目录下
        $info = $file->move(ROOT_PATH . 'public' . DS . 'uploads/advertisingby');
        if ($info) {
            // 成功上传后 获取上传信息

            // 输出 20160820/42a79759f284b767dfcb2a0197904287.jpg
            $path = $info->getSaveName();
            $data =[
                 'title'=>$result['title'],
                 'describe'=>$result['describe'],
                 'carousel_url'=>$result['carousel_url'],
                 'upload_path'=>$path,
                 'upload_time'=>Date('Y-m-d H:i:s',time()),
            ];

              //把以上数组信息输入数据库
            $end = Db::table('lt_carouser_pic')->data($data)->insert();
            if($end>0){
                return $this->success('添加成功', url('admin/Advertisingby/index'));
            }else{
                //如果信息上传失败则删除图片
                return $this->error('添加失败');
            }


        } else {
            // 上传失败获取错误信息
            echo $file->getError();

        };
    }


    /**
     * 显示指定的资源
     *
     * @param  int  $id
     * @return \think\Response
     */
    public function read($id)
    {
        //
    }

    /**
     * 显示编辑资源表单页.
     *
     * @param  int  $id
     * @return \think\Response
     */
    public function edit($id)
    {
        //var_dump($id);
        //从Db数据库里查询修改的数据
        $data = Db::table('lt_carouser_pic')->find($id);
         //  var_dump($data);
        //渲染出添加页面
        return view('Advertising/advedit',[
            'data'=>$data,
        ]);
    }

    /**
     * 保存更新的资源
     *
     * @param  \think\Request  $request
     * @param  int  $id
     * @return \think\Response
     */
    public function update(Request $request, $id)
    {
       // var_dump($request,$id);
        //获取文件信息
        $data = $request->put();
//        var_dump($data['path']);
        //获取上传的图片
        $file = request()->file('upload_path');
        if(!empty($file)){
            //修改照片的时候
            $info = $file->move(ROOT_PATH . 'public' . DS . 'uploads/advertisingby');
            $result=$info->getSaveName();
            $two = [
                'title'=>$data['title'],
                'describe'=>$data['describe'],
                'carousel_url'=>$data['carousel_url'],
                'upload_path'=>$result,
            ];

//            删除已有的原文件

//            unlink('/uploads/advertisingby/'.str_replace('\\','/',$data['path']));


            $end = Db::table('lt_carouser_pic')->where('id', $id)->update($two);
            if ($end) {
                return $this->success('编辑成功', url('admin/advertisingby/index'));
            } else {
                return $this->error('编辑失败');
            }
        }else{
            //没有修改照片的时候
            $data = [
                'title'=>$data['title'],
                'describe'=>$data['describe'],
                'carousel_url'=>$data['carousel_url'],
            ];

            $end = Db::table('lt_carouser_pic')->where('id', $id)->update($data);
            if ($end) {
                return $this->success('编辑成功', url('admin/advertisingby/index'));
            } else {
                return $this->error('编辑失败');
            }

        }




    }

    /**
     * 删除指定资源
     *
     * @param  int  $id
     * @return \think\Response
     */
    public function delete($id)
    {
        $result = Db::table('lt_carouser_pic')->delete($id);

        if ($result) {
            $info['status'] = true;
            $info['id'] = $id;
            $info['info'] = 'ID为:' . $id . '的数据删除成功';
        } else {
            $info['status'] = false;
            $info['id'] = $id;
            $info['info'] = 'ID为:' . $id . '的用户删除失败,请重试!';
        }
        return json($info);
    }
}
